java - HSQL 中缺少用于测试的序列
全部标签 在RSpec中,我有创建新线程的函数,并在该线程内执行一些操作——在我的例子中,调用TCPSocket#readline。这是现在的功能:defreadThread.newdowhileline=@socket.readline#TODO:stuffendendend由于线程调度,如果这样写我的测试会失败:it"readsfromsocket"dosubject.socket.should_receive(:readline)subject.readend目前我知道解决这个问题的唯一方法是使用sleep0.1。有没有办法适本地延迟测试,直到该线程运行? 最佳
在我的Rails4升级之后,尝试为我的任何ActiveRecord类创建一个新记录NoexplicitconversionofSymbolintoString例如,这里是我的链接的links_params方法deflink_paramsparams.require(:link).permit(:url_address,:group_id,:alt_text,:version_number,:position,:content_date,:verified_date)#Thisisline157end#line118is:@link=Link.new(link_params)但是我明白了
我有一个Sinatra应用程序,它根据用户是否登录以只读或可编辑的方式提供页面。Controller设置一个变量@can_edit,View使用它来隐藏/显示编辑链接。我如何在测试中测试@can_edit的值?我不知道如何在Rack::Test下获取Controller的当前实例。我使用class_eval来stubController中的logged_in?方法,但我不得不求助于检查last_response.body我的编辑链接以查看是否设置了@can_edit。如何直接测试@can_edit的值? 最佳答案 不幸的是,如果不修
我想测试是否使用特定参数递归调用方法。我的方法:classRecursabledefrec(arg)rec(7)unlessarg==7endenddescribeRecursabledoit"shouldrecurse"dor=Recursable.new('test')r.should_receive(:rec).with(0).orderedr.should_receive(:rec).with(7).orderedr.rec(0)endend出乎意料的是,RSpec失败了:expected:recwith(7)once,butreceivedit0times知道我的方法有什么问
在定义const_missing时,我对Ruby的行为感到非常困惑和class中的其他类方法定义而不是使用defself.foo句法。我正在尝试做这样的事情:classFooclass我主要使用class定义类方法的语法。但是,它没有按预期工作。const_missing永远不会被调用。以上结果导致NameError。像这样定义这两种方法按预期工作:defself.fooputsMISSINGenddefself.const_missing(name)puts"#{name}missing"end我认为classsyntax只是定义类方法的另一种方式,但完全等同于defself.foo
在我实际操作的简化示例中,假设我有2次对数据库的调用:Repo.add(something_stringy)Repo.remove(something_floaty)我想对数据库调用使用mock,因为真正的调用将在别处进行测试:let(:repo){repo=double("Repo")repo.should_receive(:add).with(instance_of(String))repo.should_receive(:remove).with(instance_of(Float))repo}before{FakeKlass.const_set:Repo,repo}这一切都很好
我需要在我的public/404.html页面上使用I18napi。如果我添加到404.html页面:我收到如下错误消息:Cannotuset('.page_were_looking')shortcutbecausepathisnotavailable如何使用此页面的I18n功能? 最佳答案 Rails通过使用类似public/500.de.html的路径提供错误页面来支持多语言,其中de是语言环境。在Rails本身已基本崩溃的情况下使用i18n是没有意义的。如果Rails无法获得正确的本地化错误文件,它或服务器可能会提供publi
我的Rails应用程序通过了测试,但随后显示0%通过。它是一个转换为3.1的Rails3应用程序。5tests,11assertions,0failures,0errors,0pendings,0omissions,0notifications0%passed如果我生成一个新的Rails3.1应用程序,它没有这个“通过”行。1tests,1assertions,0failures,0errors,0skips两者都在1.9.2p290下运行。我尝试删除test-unit但这似乎没有什么不同,我认为没有其他突出的原因会导致它。我猜有些事情正在触发使用不同的测试运行程序。这些是为我的应用安
我编写功能测试,我需要做的测试取决于之前测试的通过情况。假设我有一个按钮可以打开一个窗口,其中有一个功能。也就是说,为了检查此功能,我需要首先检查按钮的正确操作(即打开窗口或不起作用)。所以,我需要这样做,如果单击按钮时测试失败,则测试不会运行以检查功能窗口。单独编写测试-对我来说不是一种选择。我希望看到这样的内容:describe"sometests"doopen_result=nilit"shouldcheckworkbutton"doclick_to_button()open_result=window_opened?open_result.should==trueendifop
编码和ActiveRecord序列化有什么区别?在将对象保存到数据库中时,是否有任何特定情况更适合使用其中一种方法? 最佳答案 国际研究中心:不保证RubyMarshall可以跨不同的ruby版本或不同平台上的相同ruby版本工作。因为您可能有不同的Ruby版本访问相同的序列化列,Rails使用YAML实现它的序列化。虽然速度较慢,但它确实保证您的序列化列可以被其他ruby版本、其他操作系统上的ruby以及其他编程语言读取。 关于ruby-on-rails-RubyO